

Memory protection on AVR32

Pierre Surply

Memory

External B

Interface

MPU

Conclusion

### Memory protection on AVR32 LSE Summer Week 2014

Pierre Surply

**EPITA 2016** 

Jul 19, 2014



#### AVR32 Architecture

Memory protection on AVR32

Pierre Surpl

Introduction Memory

External Bu

- 32-bit RISC microprocessor
- Modified Harvard
- Up to 15 general-purpose 32-bit registers
- Instruction length: 16 bits
- Big-endian
- Fast interrupts and multiple interrupt priority levels
- Privileged and unprivileged modes



#### AVR32 AP7

Memory protection on AVR32

Pierre Surpl

Introduction

Memory Layout

External Bi

Interrace

MΡι

- Application Processors
- 221 DMIPS @ 150 MHz
- SIMD/DSP Instructions
- Instruction and Data caches
- Memory Management Unit
- Java hardware acceleration



## NGW100 Development Board

Memory protection on AVR32

Pierre Surph

#### Introduction

Memo

External B

Interface

MPL

Conclusion



Figure: NGW100



#### AVR32 UC3

Memory protection on AVR32

Pierre Surpl

Introduction Memory

External Bu

Interface

MPL

- Flash Microcontrollers
- 91 DMIPS @ 66 MHz
- DSP Instructions
- Instruction and Data prefetch
- Memory Protection Unit
- Embedded Flash/RAM



# UC3 Development Board

Memory protection on AVR32

Pierre Surply

#### Introduction

Memor

External B

MPI

Conclusion



Figure: EVK1100



### Memory Layout

Memory protection on AVR32

Pierre Surply

Memory

Layout

Interface

MPL

Conclusion



Figure: Memory Map (0x0000000 - 0xFFFFFFF)



## Memory Layout

Memory protection on AVR32

Pierre Surply

Memory Layout

External Bu

MPU

Conclusion



Figure: Memory Map (0xC0000000 - 0xDFFFFFFF)



Memory protection on AVR32

Pierre Surply

Introduc

Memory

External Bus Interface

MPU



Figure: Synchronous DRAM 32MB - 4M x 16 x 4 banks



Memory protection on AVR32

Pierre Surph

Introducti

External Bus

Interface

MPU



Figure: EBI Conceptual schematics



Memory protection on AVR32

Pierre Surply

muodu

Memory Lavout

External Bus Interface

MPH



Figure: Generic SDRAM device



Memory protection on AVR32

Pierre Surph

Introduc

Memory

External Bus Interface

MPU



Figure: SDRAM Connection



Memory protection on AVR32

Pierre Surpl

Introduction

Memory

External Bus Interface

MDII



Figure: EBI Connections to Memory Devices



### Memory Protection Unit

Memory protection on AVR32

Pierre Surph

Introduct

Memory

External B

MPU



Figure: Overview of the AVR32UC CPU



## Memory Protection Unit

Memory protection on AVR32

Pierre Surply

Memory

External Bu

MPU

Conclusion

- Allows the user to divide the memory space into different protection regions.
- Each region is divided into 16 subregions, each of these subregions can have one of two possible sets of access permissions.

#### **AVR32 Architecture Document**

This is a simpler alternative to a full MMU, while at the same time allowing memory protection.



# MPU Exception Handling

Memory protection on AVR32

MPU

- ITLB Protection Violation
- DTI B Protection Violation
  - ITI B Miss Violation
- DTLB Miss Violation
- TLB Multiple Hit Violation



## Memory Protection Unit

Memory protection on AVR32

Pierre Surph

Memory

External B

Interface

MPU



Figure: MPU Registers



## System Registers

#### Memory protection on AVR32

Pierre Surply

Memory

External Bu

MPU



Memory protection on AVR32

Pierre Surply

IIILIOUU

Memor

External B

MPU



Figure: Basic MPU configuration



Memory protection on AVR32

Pierre Surph

Introduc

Momor

Layout

External B Interface

MPU



Figure: Application MPU configuration I



Memory protection on AVR32

Pierre Surply

Introdu

Memor

External B

MPU



Figure: Application MPU configuration II



Memory protection on AVR32

Pierre Surply

Introdu

Memor

Eutomal I

Interface

MPU

Conclusion



Figure: Application address space



Memory protection on AVR32

Pierre Surply

Introduct

Layout

External B Interface

MPU



Figure: Builtin MPU Configuration



#### Conclusion

Memory protection on AVR32

Pierre Surpl

. icirc ouip

Memory

External Bu Interface

MPL

- Not an alternative to a full MMU
  - Limited number of regions
  - Fixed size regions
- FreeRTOS-MPU
  - vTaskAllocateMPURegions()
  - portSWITCH\_TO\_USER\_MODE()
  - xTaskCreate() -> xTaskCreateRestricted()



#### Contact

Memory protection on AVR32

Pierre Surpl

ntroductio

Memory Lavout

External B

MPU

Conclusion

■ Git: git.psurply.com/atucos

■ IRC: Ptishell@irc.rezosup.org

Mail: surply@lse.epita.fr

■ Twitter: @Ptishell